package cn.kent.simple;

/**
 * 58. 最后一个单词的长度
 * 需求：求最后一个单词的长度，单词之间空格相隔
 */
public class LengthOfLastWord {

    /**
     * 求最后一个单词的长度
     * - 反向遍历 0ms
     */
    public static int lengthOfLastWord2(String s) {
        int len = s.length();
        int left, right = len;
        int res = 0;
        for (int i = len - 1; i > -1; i--) {
            if (s.charAt(i) == ' ' && res == 0) {
                right = i;
            } else if (s.charAt(i) == ' ' && res != 0) {
                return res;
            }
            left = i;
            res = right - left;
        }
        return res;
    }

    /**
     * 求最后一个单词的长度
     * - 正向 1~2ms
     */
    public static int lengthOfLastWord(String s) {
        int len = s.length();
        int left = -1, right = -1;
        int res = 0;
        for (int i = 0; i < len; i++) {
            if (s.charAt(i) == ' ') {
                left = i;
            }
            right = i;
            if (right != left) {
                res = right - left;
            }
        }
        return res;
    }

    public static void main(String[] args) {
        String s = "a";
        // String s = "  ";
        // String s = " Hello World  ";
        int i = lengthOfLastWord2(s);
        System.out.println("最后一个单词长度为：" + i);
    }
}
